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CHAPTER 1 
INTRODUCTION 

1.1 DESCRIPTION 

The RLV12 Disk Controller interfaces RL01 and RL02 disk drives to any quad- or hex-size backplane 
that uses a 16-, 18-, or 22-bit LSI-11 bus. One RLV12 controls up to four disk drives. The RLV12 
consists of one quad-size module (M8061), a BC80M cable, a drive terminator, and drive identification 
hardware. 

The RL01 and RL02 disk drives are random-access, mass-storage, subsystems that store data in fixed- 
length blocks on a preformatted disk cartridge. Each RL01 can store 5.24 million bytes, and each RL02 
can store 10.48 million bytes. The drives are 26.67 cm (10.5 in) high, self-cooled, rack-mountable units 
and come complete with a power supply. Option RLV12-AK includes one RL01 drive, and option 
RLV22-AK includes one RL02 drive. 

The RLV12 transfers data to and from the LSI-11 bus using direct memory access (DMA) transac= 
tions. This allows data transfers to occur without first going to the processor. 

1.2 FEATURES 

The RLV12 controller has the following features. 

• Single quad-size module; needs no C-D connections. 

• Supports DMA data transfers in 16-, 18-, or 22-bit addressing modes. 

• Software compatible with RLV11 controller (16- or 18-bit mode only). 

• Supports 22-bit addressing on an LSI-1 1 bus. 

• Controls from one to four RL01/RL02 drives. 

• Memory parity error abort feature for use with memories that have a parity option. 

1.3 SPECIFICATIONS 
1.3.1 RLV12 Disk Controller 

Module 
Size 



Power Requirements 



Bus Loads 

ac bus loads 
dc bus load 

Addressing Modes 
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1 quad-size module, M8061 

Height: 26.56 cm (10.457 in) 
Width: 1.27 cm (0.5 in) 
Length: 22.70 cm: (8.94 in) 

+ 5 Vdc ± 5% at 5.0 A 
+ 12 Vdc ± 5% at 0.1 A 



2.7 
1 



16-, 18-, and 22-bit (determined by user) 



Minimum Configuration 
for 22-Bit Address Mode 



Limitations 



Drives per Controller 

LSI-11 Bus-Addressable 
Registers 

Base Device Address 



Device Interrupt Vector 
Data Transfer Rates 

Error Detection Capability 



Maximum Cable Length 
Controller to Last Drive 

Environment Specifications 
Temperature 

Storage 
Operating* 

Relative Humidity 

Storage 
Operating 

Altitude 

Not operating 
Operating* 

Airflow 
Operating 



'Reduce the maximum operating 
above sea level. 



H9275-A or similar backplane that supports 22-bit addressing, and 
memory capable of 22-bit addresses, such as the MS VI 1-L or the 
MSV11-P. 

The RLV12 will not fit in the dual-height LSI-1 1 mini-series H9281 
backplane. 

Up to four RL01 and RL02 drives in any combination 
8 (5 are used; 3 are not used) 

Selected by jumpers as follows. 

Addressing Mode Base Device Address 



16-bit 
18-bit 
22-bit 



174400 8 
774400 8 
17774400 8 



0001608, jumper selectable 

4.9 jits/word (avg) drive to controller, controller to memory 
3.9 /us/word (peak) drive to controller 
2.0 jus/word (peak) controller to memory 

Cyclic redundancy check (CRC) on data and headers 

Memory parity error abort for use with memories that have parity 
checking 

30 m (100 ft) 



-40° C to 66° C (-40° F to 150° F) 
5° C to 60° C (41° F to 110° F) 



1 0% to 90%, noncondensing 
10% to 90%, noncondensing 



9 km (5.6 mi) max 
2.4 km (1.5 mi) max 



Max temperature rise across module must not exceed 10° C 
(18° F) input to output, 
temperature by 1.8° C for each 1000 m altitude above sea level or 1 0 F for each 1000 ft 
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1.3.2 RL01/RL02 Disk Drives 

Storage Type 
Medium 

Recording Surfaces 
Magnetic heads 

Recording Capacity (formatted) 



Cylinders per cartridge 
Tracks per cylinder 
Tracks per cartridge 
Sectors per track 
Bytes per sector 
Bytes per track 
Bytes per cylinder 
Bytes per cartridge 

Recording Method 

Performance 

Transfer Rate 



tt_„j r»~„!i: — : t: — . ~ 

ucau r uMuumiig 1 uiic 



Revolution Latency 

Operating Environment 

Temperature Range 
Relative Humidity 
Wet Bulb Temperature 
Altitude 

Heat Dissipation 
Operation 

Start Time 
Stop Time 

Revolutions per Minute 



Magnetic disk cartridge 
2 data surfaces 
2 read/ write heads 



RL01 


RL02 


256 


512 


2 


2 


512 


1024 


40 


40 


256 


256 


10,240 


10,240 


20,480 


20,480 


5.24 M 


10.48 M 



Modified frequency modulation (MFM) 



40-sector (16-bit data words): 

4.9 jus/word (avg) drive to controller, controller to memory 
3.9 /xs/word (peak) drive to controller 

c c / ^\ 

~> j 1113 \^avg; 

17 ms (one track) 
100 ms (max) 

12.5 ms (avg) 



10° C to 40° C (50° F to 104° F) at sea level 
10% to 90%, noncondensing 

28° C (82° F) max 

Up to 2400 m (8000 ft) at max temperature of 36° C (96° F) 
150 W (546 Btu/hr) 



50 s 
30 s 
2400 
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Power 

Drive 

Starting Current 

Mechanical Drive 
Size 

Weight 
Mounting 

Cartridge 

Standard Cable Lengths 
Power cord 

Controller to First Drive 
Drive to Drive 
Optional Drive Cables 



Single-phase 

5 A (rms) max, 120 V, 47/63 Hz 
2.5 A (rms) max, 240 V, 47/63 Hz 



48 cm wide X 63.4 cm deep X 27 cm high (19 in wide X 25 in 
deep X 10.5 in high) 

33.75 kg (75 lb) 

The drive mounts on slides in a standard 48.26 cm (19 in) cabinet 
(provided). Recommended max height from floor is 18.9 cm (48 
in). 

Embedded servo 

Top loading cartridge with 2 data surfaces. 



2.74 m (9 ft) 
1.83 m (6 ft) 
3.05 m (10 ft) 



Cable 

BC20J-20 
BC20J-40 
BC20J-60 



Part No. 

7012122-20 
7012122-40 
7012122-60 



Length 

6 m (20 ft) 
12 m (40 ft) 
18 m (60 ft) 



NOTE 

Total length of cable(s) from controller to the last 
drive must not exceed 30 m (100 ft). 
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CHAPTER 2 

FUNCTIONAL DESCRIPTION 

2.1 INTRODUCTION 

The RLV12 controller interfaces the RL01 and RL02 disk drives to a 16-, 18-, or 22-bit LSI-11 bus. 
One RLV12 can support up to four RL01 and RL02 disk drives in any combination. The RLV12 mod- 
ule, M8061, has the LSI-1 1 bus transceivers and decoders, programmable registers, the controller tim- 
ing and sequence logic, and the data formatting circuits necessary to read and write on the disk. 

The main sections of the RLV12 are shown in Figure 2-1. The RLV12 has the following five program- 
mable registers. 

Control/status register (CSR) 
Bus address register (BAR) 
Disk address register (DAR) 
Multipurpose register (MPR) 

Bus address extension register (BAE) (22-bit addressing only) 

These registers can be addressed like any memory location. The CSR is always written last of these five 
registers because it starts the microsequencer operation. 

An RLV12 program can selectl6-, 18-, or 22-bit LSI-11 bus addressing. When not enabled for 22-bit 
addressing, the module is software compatible with and can replace the RLV1 1 or RLV21. 

NOTE 

The RLV12 may be used in a 16- or 18-bit system 
while configured to a 22-bit operation (factory ship- 
ped configuration) provided it is the only RLV12 in 
the system. 

To issue a command to the RLV12, the processor first places the address of the register on the LSI-1 1 
bus. Then it places the data on the bus. The RLV12 controller decodes the address and channels the 
data to the correct register. The processor loads the bus address register (BAR) with bits 0 through 15. 
If 18- or 22-bit addressing is used, the processor also loads the bus address extension register (BAE) 
with bits 16 through 21. Bits 16 and 17 may also be written to or read from the control/status register 
(CSR). The CSR is loaded in the same way. 

Once the command is written into the control/status register, the RLV12 starts a microsequencer rou- 
tine. The microsequencer decodes the command and branches to an address in the control store 
PROMs. There the microsequencer finds a routine for the command issued. The microsequencer then 
generates the control signals needed to channel the data through the controller. 

Included on the controller are error detection features, such as the memory parity error abort feature 
for use with memories that have parity error checking. When reading system memory, data bits 16 and 
17 from the bus are checked for a parity error. If an error is detected, the current command to the 
controller is aborted. 
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f igure 2-1 RLV 12 Block Diagram 



The RLV12 has a 256 X 16-bit RAM to store data for or from direct memory access (DMA) transac- 
tions. The RAM is a first-in, first-out (FIFO) memory that can store up to 256 words of data. 

During a write command, a FIFO serializer is used with the FIFO RAM to convert parallel data into 
serial format to be written on the disk. During a read command, the FIFO serializer converts the serial 
data into parallel data to be loaded into the FIFO RAM. 

2.2 BUS PROTOCOL 

The bus protocol logic (Figure 2-2) generates the control signals to read from or write to the controller. 
This logic uses a DC004 as a bus protocol chip. Two negative logic decoders and one positive logic 
decoder provide the read and write signals to the five RLV12 registers: CSR, BAR, DAR, MPR, and 
BAE. The following events occur. 

1. At addressing time, R SYNC H clocks in the address bits (TSDAL 1, 2 and 3). These ad- 
dress bits are decoded to read or write to the five registers. 

2. The DC004 generates a slave reply signal, SRPLY H, that becomes BRPLY L to the proces- 
sor and completes the LSI- 11 bus protocol. 
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Figure 2-2 Bus Protocol Logic 
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3. A single rank synchronizer monitors controller ready (CRDY) to enable the slave device (the 
addressed register). MRPLY L clocks in CRDY and generates S DEV EN H. 

4. When CRDY is asserted, the RLV12 is ready to accept another command. 

5. The signals XMIT H and REC H go to the DC005 transceivers that interface the LSI- 1 1 bus 
and the 16-bit three-state DAL bus. 

2.3 BUS TRANSCEIVERS 

The bus transceivers on the RLV12 are DC005s, as shown in Figure 2-3. These transceivers transmit 
and receive both data and address information. They interface the LSI-1 1 BDAL 0-15 H signals and 
the RLV12 TS DAL 0-15 H bus/address signals. BBS7 L must be asserted during address time to 
enable the transceivers. The transceivers are controlled by the signals XMIT H and REC H from the 
bus protocol logic. 

The jumper pins connected to the transceivers select the device address and the interrupt vector of the 
RLV12. 
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Figure 2-3 Bus Transceivers 



2.4 PROGRAMMABLE REGISTERS 

The five programmable registers of the RLV12 interface to a three-state bus (TS DAL BUS). These 
registers receive address, data, and control information, via the bus, and they return data and status 
information on the same bus. 
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2.4.1 Bus Address Register (BAR) 

The BAR (Figure 2-4) has two DC006 binary counters. The BAR is loaded with the 16-bit bus address 
to which the first word of a DMA transfer is to be made. The signal WR BAR L enables the register to 
load this address. 
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Figure 2-4 Bus Address Register (BAR) Circuit 



2.4.2 Bus Address Extension Register (BAE) 

The BAE (Figure 2-5) is a 6-bit register for the extended address bits, 16 through 21. For 22-bit ad- 
dressing, the BAE is loaded from TS DAL 0-5 using a write BAE command. 

For 18-bit addressing, the extended address bits 16 and 17 can be loaded either into BAE bits 0 and 1 or 
into CSR bits 4 and 5. 

NOTE 

Writing CSR bits 4 and 5 modifies BAE bits 0 and 1 
and vice versa. 

2.4.3 Disk Address Register (DAR) 

The DAR (Figure 2-6) holds the next sector address to read or write data on the disk. After each sector 
is read or written, the contents of the DAR is incremented by 1 . The output of the DAR goes to the 
DAR serializer. 

During a Seek command, the DAR is used for the head selected, the direction to travel, and the cylin- 
der address difference. During a Read, Write, or Write Check command, the DAR is used for the head 
selected, the next sector address to read or write, and the cylinder address. During a Get Status com- 
mand, the DAR is used to get the drive status and to clear the drive error register of soft errors. 

The DAR serializer has two 8-bit shift registers that load parallel data in and shift serial data out. The 
DAR serializer sends the data to the header compare circuit. 
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Figure 2-5 Bus Address Extension Register (BAE) Circuit 
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Figure 2-6 Disk Address Register (DAR) Circuit 
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2.4.4 Control/Status Register (CSR) 

The CSR (Figure 2-7) is a holding register for the command to the microsequencer. The register also 
holds the interrupt enable bit, the controller ready signal, the drive select bits, and error flags. A com- 
mand to read the CSR gets status information as shown in Table 2-1. 
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Figure 2-7 Control/Status Register (CSR) Circuit 



When set by the hardware, the controller ready flip-flop indicates that the RLV12 is ready to accept a 
command. The CRDY bit in the CSR is cleared by software. After this bit is clear, the firmware-gener- 
ated signal PLS OPI H starts the OPI watchdog timer. 

The watchdog timer allows 550 ms for the controller to complete an instruction. The timer prevents the 
controller from taking too much time to perform an instruction and keeping out other instructions. If 
the instruction is not complete within 550 ms, the timer clocks the OPI flip-flop, enabling OPI H, which 
turns off the controller. 
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Some of the CSR status error signals have two meanings depending on the state of the OPI flip-flop. 
When the D/H CRC flag is set without OPI H set, a data CRC error occurred; with OPI H set, a 
header CRC error occurred. 

When the DLT/HNF flag is set without OPI H set, a data late error occurred; with OPI H set, a 
header not found error occurred. 

During a DMA transfer, the NXM one-shot allows 10 fxs for- the addressed memory location to send and 
return BRPLY L. This one-shot prevents the RLV12 from indefinitely holding the LSI-1 1 bus. If the 
one-shot times out, it clocks the NXM flip-flop, setting NXM H, and releases the LSI-1 1 bus. 

If NXM H is set without OPI H set, a nonexistent memory error occurred. If NXM H is set with OPI 
H set, a memory parity error occurred. (A memory parity error forces both the NXM flip-flop and the 
OPI flip-flop set.) 

Any error that occurs also sets status bit 15. 



Table 2-1 Control/Status Register Bits 



CSR Bit(s) 


Status Information 


0 


Drive ready (DRDY) 


1-3 


Command function code (F0, Fl, F2) 


4, 5 


Extended address bits 16 and 17 (DAL 16-17) 


6 


Interrupt enable (IE) 


7 


Controller ready (CRDY) 


8, 9 


Drive selected (DS) 


10 


Operation incomplete (OPI) 


1 1 


Data CRC error (DCRC) 


10, 1 1 


Header CRC error (HCRC) 


12 


Data late (DLT) 


10, 12 


Header not found (HNF) 


13 


Nonexistent memory (NXM) 


10, 13 


Parity error abort (PAR ERR) 


14 


Drive error (DE) 


15 


Error flag (ERR) 



2.4.5 Multipurpose Register (MPR) 

The MPR has three functions and uses different circuits depending on the command being performed. 

1 . Word Count Register - During a Read Data or Write Data command, the MPR functions as 
a word count (WC) register and uses the same circuit as the bus address register, shown in 
Figure 2-4. Before either command is issued, the number of words to be transferred (the word 
count) is written into the MPR. The words transferred go through one of the FIFO buffers to 
the FIFO memory (see Paragraph 2.4.6). At the end of each sector read or written, the word 
count is incremented. When the count is complete, the word count overflow (MAX-C H in 
Figure 2-4) clocks the word count flip-flop and ends the data transfer. 

2. Status Register - Following a Get Status command, the MPR functions as a status register. 
The controller places the disk status information in the FIFO output buffer, shown in Figure 
2-8. The disk status word from the selected drive is placed in this buffer and can be read by 
reading the MPR. (See Paragraph 4.5.3.) 
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3. Memory Buffer Register - Following a Read Header command, the MPR functions as a 
memory buffer register. The controller places the three header words in the FIFO memory. 
Reading the MPR places the header words, one at a time, in the FIFO output buffer. To read 
the three header words requires three successive read MPR instructions. (See Paragraph 
4.5.2.) 



2.4.6 FIFO Memory, FIFO Serializer, and Word Difference Counter 

The FIFO memory is a first-in, first-out 256 X 16-bit RAM that can store up to 256 data words. A 
FIFO serializer takes serial data from the disk, makes it parallel, and places it in the FIFO memory. 
The FIFO serializer also takes parallel data out of the FIFO memory, makes it serial, and sends it to 
the disk. See Figure 2-8. 

A word difference counter keeps track of the number of words coming from the disk to the FIFO buf- 
fer. After four words are read from the disk, the word difference counter signals the microsequencer to 
start a DMA transaction. 
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Figure 2-8 FIFO RAM, Buffers, and Serializer 



2.5 DATA SOURCE MULTIPLEXER AND CRC GENERATOR 

Data that is to be written on the disk goes to a data source multiplexer (see Figure 2-1). MUX SEL 0, 
1, and 2 determine which of the following inputs reaches the multiplexer output. 

Serial Input Source 

SER DA (disk address) DAR (disk address register) 

SER DATA OUT FIFO serializer 

DS DATA Data separator 

CRC CRC checker/generator 

The multiplexer's serial output, MUX DATA H, goes to the write encoder precompensation circuit to 
be written on the disk. At the same time, a CRC check word is being created by the CRC check- 
er/generator. This check word is then added to the end of the data field of the sector. 

When the header or sector is read from the disk, the data is again sent through the CRC check- 
er/generator. Any errors in the data or in the CRC word are detected, and a data CRC (DCRC) or a 
header CRC (HCRC) error bit is set in the control/status register. 

2.6 MICROSEQUENCER, CONTROL STORE PROMS, AND BUFFER REGISTER 

The microsequencer decodes the function commands of the CSR and points to an address in the control 
store PROMs, where the routine resides, to execute the command. The microsequencer sends an ad- 
dress (PR ADD 0-9 H) to the control store PROMs. (See Figure 2-9.) 
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Figure 2-9 Microsequencer, Control Store PROMs, and Buffer Register 
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The control store PROMs receive the address from the microsequencer and generate a 24-bit micro- 
instruction at the outputs (PR OUT 0-23 H). The PROM outputs go to a buffer register, which is 
divided into five fields as follows. 

1. Instruction field 

2. T MUX SEL field 

3. T FLAG X L (test Hag don't care) 

4. Constant field 

5. LD CTRL register field 

2.6.1 Buffer Register Fields 

The instruction field signals (INSTR 0, 1, 2 and 4) go to the conditional branch multiplexer to provide 
the microsequencer with the next address to access. These instruction signals generate the select inputs 
(SO H and SI H) and the enable inputs (FE L and RE L) to the microsequencer. INSTR 3 goes 
directly to the push/pop input of the microsequencer. 

The T MUX SEL field signals select one of the status flags to enable the instruction from the condi- 
tional branch multiplexer. One of the status flags that go to the status flag multiplexer is enabled to 
pass to the dual-rank synchronizer. The status flag becomes T FLAG L and goes to the select input of 
the conditional branch multiplexer selecting the instruction field signals from the buffer register. 

The T FLAG X L signal from the control store buffer register allows the microcode to branch on a 
specific flag as follows. 

1 . When T FLAG X L is low, the instruction in the instruction field is executed unconditionally. 
(The state of T FLAG L is a don't care condition.) 

2. When a status flag appears on the dual-rank synchronizer, it asserts T FLAG L. If at the 
same time T FLAG X L is high (unasserted), the microsequencer conditionally executes the 
instruction in the instruction field. 

3. If both T FLAG X L and T FLAG L are high, the microsequencer skips to the next instruc- 
tion in the control store PROMs. 

The constant field has two purposes. It provides a direct input to the microsequencer, and it provides 
inputs to load one of three control registers (A, B, and C) and the two D-pulse generators. (See Para- 
graph 2.7.) 

When loading a control register or pulse generator, the signals LD CTRL A, B, or C are decoded to 
determine which register or pulse generator to load. 

2.6.2 Fatal Error Clearing Logic 

If a fatal pulse occurs it halts the clock on the RLV12 and sets CRDY H. CRDY H generates ZERO 
L, which resets the microsequencer to location zero, where it stays until the controller is restarted 
(CRDY is cleared). When the controller is accessed, DEV SEL H clocks and initializes the micro- 
sequencer. 
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2.7 CONTROL REGISTERS AND PULSE GENERATORS 

The control signals for the RLV12 logic, such as clock selection, FIFO control, and data path control, 
come from three control registers (A, B, and C) and two D-pulse generators. These registers and D- 
pulse generators are loaded from the constant field of the microsequencer's control store buffer. They 
provide the following functions. 

1 . Register A provides clock selection, multiplexer selection, and some enable signals. 

2. Register B provides register selection and FIFO control. 

3. Register C provides data path control. 

4. Two D-pulse generators, one positive and one negative, provide pulses for clearing, in- 
crementing, and decrementing the logic. 

2.8 WRITE ENCODER AND PRECOMPENSATION LOGIC 

The write encoder converts binary data into modified frequency modulated (MFM) data, which is re- 
corded on a disk. 

MFM is a magnetic recording method for disk drives, in which a clock signal is encoded in the flux 
transitions recorded on the disk. When reading data from the disk, one can synchronize on the data 
transitions, and with a phase-locked loop and MFM decoder, recover the clock and data. 

Each bit cell (Figure 2-10) can have a transition at its beginning or at its center or may have no transi- 
tion at all. Each 1 produces a transition at the center of the bit cell time; a 0 preceded by a 1 produces 
no transition; and a 0 preceded by a 0 produces a transition at the beginning of the bit cell time. There- 
fore, with MFM encoding, flux transitions are always present even with an all 0s or all Is data pattern. 
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Figure 2-10 MFM Encoding 



A problem with this recording method is that adjacent flux transitions appear to be moved from where 
they were written. This is called peak shifting. The direction of the peak shift is linked to the position of 
the MFM pulses. Two pulses close together shift the peaks of the read voltage away from each other. 
(See Figure 2-11.) 
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To offset this peak shifting, the write encoder uses a delay line to shift the data in the opposite direction 
to that expected by the peak shift. This shifting of the data is called precompensation. 
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Figure 2-12.) All nine taps go to a multiplexer. (The center tap is a reference line.) 

The select lines to the multiplexer come from a PROM and binary counter, which keeps a history of the 
previous data. The select lines determine whether to advance or delay the new data from the previous 
data, creating precompensated MFM data. 
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Figure 2-1 1 Peak Shift Waveform 



2-13 



8.2 MHZ 

CRYSTAL 

OSC 



8.2 MHZ 



SYS 1 H 



SYS 0 H 



D 

D-TYPE 
F/F 

C 



SYS 0 H 



-c 
-c 

r-O 



MUX DATA H — 
FROM 

DATA SOURCE 
MULTIPLEXER 



PREVI- 
OUS 
DATA 
FLIP- 
FLOPS 
(1 OF 6) 




DELAY LINE 5 NS/TAP J 



PROM 



ADDR 



BINARY 
COUNT- 
ER 



R1 



SELECT- 
ABLE 
MUX 



SEL 



WRT DATA PLS H 



TO BUS INTERFACE 
TRANSCEIVERS 



LD CK 

T 

8.2 MHZ 



RO 



SYSO H 




Figure 2-12 Write Encoder and Precompensation Circuit 
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2.9 DATA SEPARATOR READ CIRCUIT 

The data separator read circuit (Figure 2-13) takes the MFM data from the disk drive and produces 
binary data and a clock. This circuit uses a phase-locked loop to generate a clock signal to synchronize 
to the MFM data. (A variable capacitor sets the free-running frequency of the voltage-controlled os- 
cillator (VCO). This frequency is set at the factory and should not be changed.) Then, the read circuit 
decodes the MFM data. The serial binary data then goes to the FIFO serializer, as DS DATA H, and is 
clocked in by DS CLK. 
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Figure 2-13 Data Separator Read Circuit 
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CHAPTER 3 

CONFIGURATION AND INSTALLATION 



3.1 INTRODUCTION 

This chapter provides the user or installer with information to configure and install the RLV12 in a 16-, 
18-, or 22-bit LSI-1 1 bus. The user can change the device address, interrupt vector, and memory parity 
error abort feature. 

3.2 DEVICE ADDRESS SELECTION 

Software control of the RLV12 is by means of four or five device registers - CSR, BAR, DAR, MPR, 
and BAE. Four registers are used for 16- or 18-bit addressing; five registers are used for 22-bit address- 
ing. The bus address extension register (BAE) is added for upper address bit selection for 22-bit ad- 
dressing. The usual device starting address is as follows. 

Addressing Mode Starting Address (Octal) 

16-bit 174400 
18-bit 774400 
22-bit 17774400* 

The first register, the CSR, is assigned the starting address, and the other registers are assigned the 
next sequential addresses, as shown in Table 3-1. 

The device starting address is selected by jumpers for bits 3 through 12. These jumpers are shown in 
Figure 3-1 . A jumper from the selected bit to ground (M22) decodes a 1; no juniper decodes a 0; and a 
jumper to +5 V (Ml 1) decodes an X (don't care) condition. Figure 3-2 shows the RLV12 device start- 
ing address format. 

NOTE 

For 22-bit addressing, bit A3 is not decoded in the 
starting address. 

3.3 BUS SELECTION 

The RLV12 module can be used on 16-, 18-, or 22-bit LSI-1 1 buses. When sent from the factory, the 
module operates on a 22-bit bus. Jumper Ml to M2 is installed as shown in Figure 3-1, which enables 
bank select 7 (BBS7) to be determined by the upper address bits (13-21). When the jumper is removed, 
the RLV12 has an 18-bit mode bank select 7 and can replace an existing RLV1 1 or RLV21 as the disk 
controller for RL01 and RL02 disk drives. 

NOTE 

The RLV12 may be used in a 16- or 18-bit system 
while configured to a 22-bit operation (factory ship- 
ped configuration) provided it is the only RLV12 in 
the system. 



* Factory Configuration 
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3.4 INTERRUPT VECTOR 

The interrupt vector has a range of 0 to 774. The interrupt vector is preset at the factory to 160. The 
user may select another vector by changing the jumpers for bits V2-V8, as shown in Figure 3-3. A 
connection to VEC TO BUS H (M3, shown in Figure 3-1) generates a 1 for that bit; no connection 
generates a 0. 

3.5 INTERRUPT REQUEST LEVEL 

The RLV12 interrupts at priority level 4 determined by the interrupt chip E23, a DC003. 



Table 3-1 Address Selection 



Device 
Address 


16-Bit 
Addressing 


18-Bit 
Addressing 


22-Bit 
Addressing* 


Starting 
Address Range 


160000-177770 


760000-777770 


17760000-17777760 


Starting 
Address 


1 74400 


774400 


17774400 


No. of 
Registers 


4 


4 


8 (5 are used; 3 are not) 


Registers 
Used 


CSR (174400) 
BAR (174402) 
DAR (174404) 
MPR (174406) 


CSR (774400) 
BAR (774402) 
DAR (774404) 
MPR (774406) 


CSR (17774400) 
BAR (17774402) 
DAR (17774404) 
MPR (17774406) 
BAE (17774410) 


Jumpers Used 


Tie M22 ("1") 
to Ml 7, M20, 
and M21 


Tie M22 ("1") 
to Ml 7, M20, 
and M21 


Tie M22 ("1") 
to Ml 7, M20, 
andM21; 
Tie Mil ("X") 
to Ml 2 


Interrupt 

Vector 








Vector Range 


0-774 


0-774 


0-774 


Standard 
Vector 


160 


160 


160 


Jumpers Used 


TieM3("l") 
to M6, M7, 
andM8 


Tie M3 ("1") 
to M6, M7, 
and M8 


TieM3 ("1") 
to M6, M7, 
and M8 
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Figure 3-1 RLV12 Jumper Locations 
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Figure 3-2 RLV12 Device Address Format 
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Figure 3-3 RLV12 Interrupt Vector Format 



3.6 MEMORY PARITY ERROR ABORT FEATURE 

When reading the system's optional memory with parity error detection, a parity error will set OPI and 
NXM of the CSR. This is a unique error condition that aborts the current command to the RLV12. 
This error abort feature is possible only with memories that have parity data bits. 

The RLV12 is sent from the factory with the memory parity error abort feature enabled. To disable 
parity error abort, remove the jumper between pins M24 and M25 and install a jumper between pins 
M23 and M24. (See Figure 3-1.) This feature does not have to be disabled for non-parity memories, as 
parity errors are not generated. Parity error abort uses data bits 16 and 17. 

3.7 JUMPERS THAT REMAIN INSTALLED 

The module has two jumpers, Wl and W2, that enable priority signals to pass through the module. The 
module has these jumpers installed, and they should be left in. 

Jumper Signal 

Wl CIAKItoCIAKO 
W2 CDMGI to CDMGO 

One jumper, W3, enables the word count register to automatically increment during a DMA operation. 
This jumper is used for factory testing and should be left in. 
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Two jumpers on the module disable the crystal oscillator and the voltage-controlled oscillator (VCO) 
during factory testing. These jumpers should be left in. 

Jumper Oscillator 

M26-M27 VCO 
M28-M29 Crystal 

3.8 INSTALLATION 

The RLV12 can be installed in any quad LSI-1 1 bus slot. The controller's priority level is based on its 
electrical distance from the processor module. Use the following procedure to install the module. 

1. Examine the module to make sure that the base address jumpers and vector address jumpers 
are set correctly. (See Paragraphs 3.2 and 3.4.) 

2. Check jumpers Ml and M2 for enabling the correct bank select 7 (BBS7) for the 16-, 18-, or 
22-bit LSI-1 1 bus. 

3. Check jumpers Ml 1 and Ml 2 for enabling the correct BAE register for the 16-, 18-, or 22-bit 
LSI-1 1 bus. 

4. If desired, disable the memory parity error abort feature. This feature can only be used with 
system memories that have parity options, but this feature does not have to be disabled for 
non-parity memories. (See Paragraph 3.6.) 

5. Insert the BC80M controller cable (or equivalent) into Jl on the M8061 as shown in Figure 
3-4. 

6. Insert the M8061 in the selected slot in the LSI-1 1 bus. 

7. Attach the ground strap on the cable to the metal cabinet chassis. 

8. Connect the other end of the BC80M cable to the back of the first disk drive. 

9. Continue with the disk installation. Refer to the RL01/RL02 Disk Subsystem User's Guide 
(EK-RL012-UG). 

3.9 ACCEPTANCE TESTING 

The RLV12 controller is tested by running the RLV12 diskless diagnostic test and, if a drive is at- 
tached, by running the diagnostics that exercise the RL01 and RL02 disk drive. The diskless diagnostic 
should be run first. The RLV12 diagnostics are available on different media. Contact your local Digital 
sales office for the types of media available and their part numbers. 

Run the XXDP+ diagnostics in the following order. 

1. CVRLB RLV12 Diskless Diagnostic (16-, 18-, or 22-bit mode) 

NOTE 

The RLV11 diskless diagnostic (CVRLA) is com- 
patible with the RLV12 diskless diagnostic and 
checks the same logic. However, it will not check 
22-bit addressing. 

2. CZRLG Controller Test Part 1 

3. CZRLH Controller Test Part 2 



3-5 



4. CZRLI Drive Test Part 1 

5. CZRLJ Drive Test Part 2 

6. CZRLN Drive Test Part 3 

7. CZRLK Performance Exerciser 

8. CZRLL Compatibility Test 

9. CZRLM Bad Sector File Utility 

NOTE 

The Bad Sector File Utility is not a diagnostic test. 
It is used by field service to examine the bad sector 
file on the disk and to write entries into that file. 




MB-5898 



Figure 3-4 RLV12 Installation 
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CHAPTER 4 
REGISTERS 



4.1 INTRODUCTION 

This chapter describes the functions of the bits in each of the five programmable registers. 

NOTE 

To prevent accidental writing on a disk, the RLV12 
synchronizes on controller ready (CRDY). If the 
CRDY bit in the CSR changes from clear to set 
while the processor is in ODT mode, the next read 
access of any RLV12 register produces all Os. 

4.2 CONTROL/STATUS REGISTER (CSR) 

The control/status register (Figure 4-1) is a 16-bit, word-addressable register with a standard address of 
774400 for 18-bit addressing, and 17774400 for 22-bit addressing. Bits 1 through 9 can be read or writ- 
ten; the other bits can only be read. The bit functions are described in Table 4-1. 

When the LSI-11 bus is initialized with BINIT L, bits 1-6 and 8-13 are cleared, and bit 7 (CRDY) is 
set. Bit 0 (DRDY) is set when the selected drive is ready to accept a command; otherwise, this bit is 
cleared. Bit 14 (DE) is clear as long as there is no drive error. Otherwise, this bit is set and stays set 
until the drive error is corrected; or if bit 3 (drive reset) is set in the DAR and the controller is sent a 
Get Status command, the DE bit is cleared. 

T>u 1 c / 1 o n \ ; * +u :„ ~ a-:,* „ +-^11^- — u;+^ 1 rv 1 a 

JJl l ^J_,ixiv^ 13 av^t wilvvii Lin^i v 10 a ui ivv ui wiuiuuw wiui in uilo iv/ — i-r. 

At the beginning of each controller command, error bits 10-13 are automatically cleared. At the com- 
pletion of each controller command, bit 7 is automatically set. (Bit 7 is also set if an error is detected 
during command execution.) 

4.3 BUS ADDRESS REGISTER (BAR) 

The bus address register (Figure 4-2) is a 16-bit, word-addressable register with a standard address of 
774402 for 18-bit addressing, and 17774400 for 22-bit addressing. Bits 0 through 15 can be read or 
written; bit 0 is usually written as 0. The bus address register indicates the memory location for the 
DMA data transfer during a read or write operation. The register's contents are automatically in- 
cremented by 2 as each word is transferred between the system memory and the controller. 

The bus address can be expanded for an 18-bit LSI-1 1 bus by using bits 4 and 5 (BA 16 and 17) of the 
CSR or by using bits 0 and 1 of the BAE register. 

The bus address can be expanded for a 22-bit LSI-1 1 bus by using the BAE register (BAE 16-21). 

NOTE 

When using 22-bit mode, writing CSR bits 4 and 5 
modifies BAE bits 0 and 1 and vice versa. 

The BAR is cleared by initializing the bus (BINIT L). 
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Table 4-1 CSR Word Format 



Bit(s) Name Description 



0 DRDY Drive Ready - When set, this bit indicates that the selected drive is ready to receive a command or supply 

valid read data. The bit is cleared when a Seek or head select operation is started and set when the Seek 
operation is completed. 

1-3 F0-F2 Function Code - These bits are the function code set by software to indicate the command to be executed. 



Function 






Octal 


F2 Fl 


FO 


Command 


Code 


0 0 


0 


Maintenance mode 


0 


0 0 


1 


Write Check 


1 


0 1 


0 


Get Status 


2 


0 1 


1 


Seek 


3 


1 0 


0 


Read Header 


4 


1 0 


1 


Write Data 


5 


1 1 


0 


Read Data 


6 


1 1 


1 


Read Data Without 


7 






Header Check 





4,5 BA16, 
BA17 



IE 



8, 9 



CRDY 



DSO, 
DS1 



10-13 E0-E3 



Command execution starts when CRDY (bit 7) of the CSR is cleared by software. The commands are 
described in more detail in Chapter 5. The function code is cleared by initializing the bus (BINIT L). 

Extended Address Bits - These two bits are the upper-order bus address bits for 18-bit buses. These bits 
are read and written as bits 4 and 5 of the CSR. They function as address bits 16 and 17 of the BAR. 
Writing bits 4 and 5 of the CSR also writes bits 0 and 1 of the BAE. 

Interrupt Enable - When CRDY is asserted, bit 6 allows the controller to interrupt the processor. This 
interrupt occurs at the termination of a command. Once an interrupt request is placed on the LSI- 1 1 bus, 
it is not removed until acknowledged by the LSI-11 processor even if IE (bit 6) is cleared. This bit is 
cleared by initializing the bus. 

Controller Ready - When cleared by software, this bit indicates that the command in bits 1-3 is to be 
executed. This bit is set by the controller at the completion of a command, at the detection of an error, or 
by initializing the bus. Software cannot set this bit because no registers are accessible while CRDY is 0. 

Drive Select - These bits determine which drive will communicate with the controller via the drive bus. 
These bits are cleared by initializing the bus. 

Controller Status Errors - These bits are the error code set by the controller to indicate one of the follow- 
ing errors. 



Error Code 



Octal 



E3 


E2 


El 


E0 


Error 


C< 


0 


0 


0 


1 


Operation incomplete (OPI) 


1 


0 


0 


1 


0 


Data CRC (DCRC) 


2 


0 


0 


1 


1 


Header CRC (HCRC) 


3 


0 


1 


0 


0 


Data late (DLT) 


4 


0 


1 


0 


1 


Header not found (HNF) 


5 


1 


0 


0 


0 


Nonexistent memory (NXM) 


10 


1 


0 


0 


1 


Parity error abort (PAR ERR) 


1 1 



Operation incomplete indicates that the current command was not completed within the OPI timeout peri- 
od of 550 ms. 



A data CRC error indicates that while reading the data field from the disk, an error was found. 

A header CRC error indicates that while reading the header from the disk, an error was found. The CRC 
check is performed on the first and second header words, although the second header word is always 0. 
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Table 4-1 CSR Word Format (Cont) 



Bit(s) Name Description 



10-13 E0-E3 Data late indicates that the FIFO RAM was more than half full and the controller was not able to read the 
next sequential sector. This error may occur during a Read Without Header Check command. 

Header not found indicates that an OPI timeout occurred while the controller was searching for the cor- 
rect sector to read or write. A header compare did not occur. 

A nonexistent memory error indicates that during a DMA transfer the memory location addressed did not 
respond with RPLY within 10 us. 

A memory parity error abort indicates that a parity error was detected while reading the system's optional 
memory that has parity error checking. If an error was detected, the current command to the RLV12 is 
aborted. 



14 DE Drive Error - This bit is buffered from the drive error interface line. When set, it indicates that the se- 

lected drive has flagged an error, the source of which can be determined by executing a Get Status com- 
mand. DE will not set ERR (bit 15) or CRDY (bit 7) until the usual occurrence of CRDY. 

15 ERR Composite Error - When set, this bit indicates that one or more of the error bits (bits 10-14) are set. 

When an error occurs, the current operation terminates and an interrupt routine is started if the interrupt 
enable bit (bit 6 of the CSR) is set. 

Ail error bits are cleared by initializing the bus by starting a new command, with the exception of DE and 
ERR if they were caused by a drive error. 



15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 



ERR 


DE 


NXM 


DLT 


D 
CRC 


OPI 
0 


DS1 


DSO 




IE 






F2 


F1 


FO 






PAR 
ERR 


HNF 


H 
CRC 


OPI 
1 




I 

CRDY 


I 

BA17 


I 

DRDY 



BA16 



READ ONLY 



READ/WRITE 



READ 
ONLY 



Figure 4-1 Control/Status Register (CSR) 
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BA9 


BA8 


BA7 


BA6 


BA5 


BA4 


BA3 


BA2 


BA1 


0 


I 

BA15 

V. 


BA14 


I 

BA13 


BA12 


I 

BA1 1 


BA10 




















J 



READ/WRITE 



Figure 4-2 Bus Address Register (BAR) 
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4.4 DISK ADDRESS REGISTER (DAR) 

The disk address register is a 16-bit, read/ write, word-addressable register with a standard address of 
774404 for 18-bit addressing, and 17774404 for 22-bit addressing. Its contents has one of three mean- 
ings, depending on the command being performed. 

Command DAR Function 

Seek Head selected, number of cylinders to move, direction 

Read Data Head selected, cylinder address, sector address 

or Write Data 

Get Status Send drive status to MPR; reset error registers 

The DAR is cleared by initializing the bus (BINIT L). 

4.4.1 DAR During a Seek Command 

To perform a Seek command, the program must provide the head selected (HS), direction to move 
(DIR), and the cylinder address difference (DF), as indicated in Figure 4-3. The bits are described in 
Table 4-2. 

4.4.2 DAR During a Read, Write, or Write Check Command 

For a Read, Write, or Write Check command, the DAR provides the head selected (HS) and the ad- 
dress of the first sector to be transferred (SA), as indicated in Figure 4-4. The bits are described in 
Table 4-3. As each sector is transferred, the DAR sector address increments by 1. 

4.4.3 DAR During a Get Status Command 

Both the CSR and the DAR must be programmed to perform a Get Status command. The DAR must 
be programmed as shown in Figure 4-5. Then a Get Status command is placed in the CSR. The DAR 
bits are described in Table 4-4. 

4.5 MULTIPURPOSE REGISTER (MPR) 

The multipurpose register is a 16-bit, read/ write, word-addressable register. It is accessed using the 
standard address of 774406 for 18-bit addressing, and 17774404 for 22-bit addressing. Following a 
Read Header command or a Get Status command, reading the MPR obtains sector header or drive 
status information. 

Writing to the MPR is used to set the word count. The word count is cleared by initializing the bus 
(BINIT L). 

4.5.1 Writing the MPR to Set the Word Count 

Before starting a DMA transfer, the MPR is loaded with the word count. The program must load the 
MPR with the 2's complement of the number of words to be transferred. The MPR is written in the 
format shown in Figure 4-6. The bits are described in Table 4-5. As each word is transferred, the MPR 
is automatically incremented by 1. The reading or writing operation continues until a word count over- 
flow occurs, indicating that all words have been transferred. 

The word count can range from 1 to 5120 data words. The maximum word count is limited by the 
maximum number of sectors available (40) and the maximum words per sector (128). 

NOTE 

Once written the word count cannot be read back. 
Reading the MPR does not change the word count. 
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DF8 


DF7 


DF6 


DF5 


DF4 


DF3 


DF2 


DF1 


DFO 


0 


0 


HS 


0 


DIR 


0 


1 



(RL02 ONLY) 



Figure 4-3 DAR During a Seek Command 
Table 4-2 DAR Seek Command Word Format 



Bit(s) Name Description 



0 MRKR Marker - Must be a 1. 

1 none Must be a 0, indicating to the drive that a Seek command is being issued and that the other bits in the 

register hold the Seek specifications. 

2 DIR Direction - This bit indicates the direction in which the Seek is to take place. When the bit is set, the 

heads move toward the spindle (to a higher cylinder address). When the bit is cleared, the heads move 
away from the spindle (to a lower cylinder address). The actual distance moved depends on the cylinder 
address difference (bits 7-15). 

3 none Must be a 0. 

4 HS Head Select - Indicates which head (disk surface) is to be selected: 1 = lower, 0 = upper. 
5, 6 none Reserved 

7-1 5 DF Cylinder Address Difference - Indicates the number of cylinders the heads are to move on a Seek. 
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CA8 


CA7 


CA6 


CA5 


CA4 


CA3 


CA2 


CA1 


CAO 


HS 


SA5 


SA4 


SA3 


SA2 


SA1 


SAO 



Figure 4-4 DAR During a Read, Write, or Write Check Command 



Table 4-3 DAR Read/Write Data Command Word Format 



Bit(s) Name Description 



0-5 SA Sector Address - Address of one of the 40 sectors on a track. (Octal range is 0 to 47.) 

6 HS Head Select - Indicates which head (disk surface) is to be selected: l = lower: 0 = upper. 

7-15 CA Cylinder Address - Address of one of the 256 cvlindcrs for RL01 or 512 cvlinders for RL02. (Octal range 

is 0 to 777.) 
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X 


X 


X 


X 


X 


X 


X 


X 


0 


0 


0 


0 


RST 


0 


1 


1 



Figure 4-5 DAR During a Get Status Command 



Table 4-4 DAR Get Status Command Word Format 



Bit(s) Name Description 



0 MRKR Marker - Must be a 1. 

1 GS Get Status - Must be a 1, indicating to the drive to send its status word. At the completion of the Get 

Status command, the drive status word is read into the controller multipurpose register (MPR). With this 
bit set, bits 8-15 are ignored by the drive. 

2 none Must be a 0. 

3 RST Reset - When this bit is set, the disk drive clears its error register of soft errors before sending a status 

word to the controller. 

4-7 none Must be a 0. 
8-15 none Not used. 
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1 


1 


1 
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WC4 


WC3 


WC2 


WC1 


WCO 



WC12 



WC10 



WC1 1 



Figure 4-6 Writing the MPR to Set the Word Count 



Table 4-5 MPR Word Count Format 



Bits Name Description 



0-12 WC Word Count - This is the 2's complement of the total number of words to be transferred. 
13-15 none Must be all Is for word count in correct range. 
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4.5.2 Reading the MPR After a Read Header Command 

When a Read Header command is executed, three words can be sequentially read from the MPR, as 
shown in Figure 4-7. The first word includes the sector address, the head selected, and the cylinder 
address. The second word is all Os. The third word has the header CRC information. 

4.5.3 Reading the MPR After a Get Status Command 

After a Get Status command is executed, a status word is stored in the MPR, as shown in Figure 4-8. 
The status word from the selected disk drive includes information on the functional state of the drive 
and any drive errors. The bits are described in Table 4-6. 

4.6 BUS ADDRESS EXTENSION REGISTER (BAE) 

The bus address extension register is a 6-bit read/write register used to drive address bits 16-21 for a 
22-bit LSI-1 1 bus. The BAE has a standard address of 17774410 for 22-bit addressing. A write to the 
BAE loads TS DAL 0-5 into BAE 0-5, shown in Figure 4-9. Reading the BAE enables bank select 7 
(BBS7 L) to the LSI-1 1 bus. (A jumper must be connected between Ml and M2 on the controller to 
enable 22-bit addressing; see Chapter 3.) When address bits 3 3-21 are all Is, the RLV12 drives BBS7 
L to direct data to the I/O page. 

The two least significant bits of the BAE (bus address lines 16 and 17) are mirrored in bits 4 and 5 of 
the CSR. The same bits can be read or written as CSR bits 4 and 5 or BAE bits 0 and 1. 

NOTE 

Writing CSR bits 4 and 5 modifies BAE bits 0 and 1 
and vice versa. 

The BAE register is cleared by initializing the bus (BINIT L). 



15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 



1ST 
WORD 


LAO 




LAO 


LAO 




LAO 


OA, 


OA, 


UAU 


„„ 


SAO 


SA4 


bAJ 


bA, 


bA I 


bAU 




15 


14 


13 


12 


1 1 


10 


09 


08 


07 


06 


05 


04 


03 


02 


01 


00 


2ND 
WORD 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 




15 


14 


13 


12 


1 1 


10 


09 


08 


07 


06 


05 


04 


03 


02 


01 


00 


3RD 
WORD 



































CRC13 


CRC1 1 


CRC9 


CRC7 


CRC5 


CRC3 


CRC1 



CRC14 CRC12 CRC10 CRC8 CRC6 CRC4 CRC2 CRCO 

MR-5757 



Figure 4-7 Reading the MPR After a Read Header Command 
(Three Header Words) 
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Figure 4-8 Reading the MPR After a Get Status Command 
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Table 4-6 MPR Status Word Format 



Bit(s) Name Description 



0-2 



STA, 
STB, 
STC 



These bits (A, B, and C) define the state of the drive as follows. 



10 

1 1 

12 

13 
14 
15 



BH 
HO 

CO 

HS 

DT 

DSE 

VC 

WGE 

SPE 

SKTO 

WL 

HCE 

WDE 



c 


B 


A 


State of Drive 


0 


0 


0 


Load state 


0 


0 


1 


Spin up 


0 


1 


0 


Brush cycle 


0 


1 


1 


Load heads 


1 


0 


0 


Seek track counting 


1 


0 


1 


Seek linear mode (lock on) 


1 


1 


0 


Unload heads 


1 


1 


1 


Spin down 



Brush Home - Asserted when the brushes are not over the disk. 
Heads Out - Asserted when the heads are over the disk 

Cover Open - Asserted when the cover is open or the dust cover is not in place. 
Head Select - Indicates the head selected: 1 = lower, 0 = upper. 
Drive Type - Indicates the type of disk drive: 0 = RL01, 1 = R.L02. 
Drive Select Error - Indicates multiple drive selection is detected. 

Volume Check - VC is set every time the drive goes into load heads state. This asserts a drive error at the 
controller, but not on the front panel. VC is an indication that the program does not know which disk is 
present until it has read the serial number and bad sector file. (The disk might have been changed while 
the heads were unloaded.) 

Write Gate Error - Indicates that the write gate was asserted when the drive was not ready, the sector 
pulse was asserted, or the drive was write-locked. 

Spin Error - Indicates that the spindle did not reach full speed within a specific time, or it is turning too 
fast. 

Seek Time Out - Indicates the heads did not come onto track within a specific time during a Seek com- 
mand. 

Write Lock - Indicates write lock status of selected drive: 0 = unlocked; 1 = protected. 

Head Current Error - Indicates write current was detected in the heads when write gate was not asserted. 

Write Data Error - Indicates write gate was asserted, but no pulses were detected on the write data line. 
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Figure 4-9 BAE Register Word Format 
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CHAPTER 5 

COMMANDS 



5.1 INTRODUCTION 

This chapter describes the commands that are sent to the control/status register, FO, Fl, F2, to perform 
a specific disk function. The number in parentheses after each command is the octal code for the com- 
mand. 

A prerequisite to issuing any command is that CRDY (controller ready) is set in the CSR (bit 7). Soft- 
ware cannot set this bit and cannot access any register if this bit is 0. 

At the start of each new command, the error bits in the CSR (bits 10-13) are automatically cleared. At 
the completion of each command, the CRDY bit is automatically set. (CRDY is also set if an error is 
detected during command execution.) 

5.2 WRITE CHECK (1) 

Prerequisite: The disk heads must be placed at the correct track by issuing a Seek command if neces- 
sary. The BAR must be loaded with the address of the first location of the data block in system memo- 
ry. The word count of the data block length must be loaded in the MPR. The DAR must be loaded with 
the starting disk address location. 

The Write Check command is used to verify that data was written on the disk correctly. It is used after 
writing a block of data on the disk by the Write Data command. 

The Write Check command reads this same block of data and compares it with the data in the com- 
puter's system memory. Because this comparison is performed in the controller, this source data must 
be transferred out of memory into the controller's FIFO buffer. A bit-by-bit comparison of the header 
on the disk and the contents of the disk address register checks for a header match. 

Once a header match is found and the header CRC validates the match, the 128 words of data are read 
from the disk. This data is then compared with the serial data coming out of the FIFO serializer (SER 
DATA OUT). A compare error or a data CRC error sets bit 1 1 in the CSR. 

NOTE 

When writing only a partial sector (less than 128 
words), words with all 0s are used to fill the remain- 
ing portion of the sector. 

5.3 GET STATUS (2) 

Prerequisite: The software should first verify that the controller ready bit is set. (The drive does not 
have to be ready.) Then a status request word must be loaded into the DAR. Bits 0 and 1 must be set; 
bit 3 (reset) can be either 0 or 1; and all other bits must be 0s. (See Paragraph 4.4.3.) 

A Get Status command in the CSR asks the selected disk drive to return information about its current 
operation and error status. If the reset bit (bit 3) is set in the DAR, the disk drive first clears its error 
register of all soft errors before sending back the drive status. When the drive sends back its status 
word, it is stored in the FIFO buffer and can be accessed by reading the MPR. 
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DRDY (drive ready) does not have to be set to issue a Get Status command. For example, a Get Status 
command can be issued during a seek operation or when the drive is in its load state. 

5.4 SEEK (3) 

Prerequisite: The present location of the disk head must be known. This can be determined with a Read 
Header command. Then the software must compute the cylinder address difference (DF) needed by the 
drive to move the heads to the new location. Then the DAR must be loaded with the head positioning 
information. The DAR must include the number of cylinders to move (bits 7-15), the head select bit 
(bit 4), and the direction to move (bit 2). Bits 6, 5, and 1 must be set to 0; bit 0 must be set to 1. 

The Seek command shifts the contents of the DAR to the disk drive. The DAR contains the head se- 
lected for the next data transaction, the cylinder difference address, and the direction of movement. 
Once the drive receives this head positioning information, it moves the head to the new track location. 

5.5 READ HEADER (4) 

Prerequisite: A Get Status command must be issued and DRDY must be set in the CSR. 

The Read Header command reads the first header found on the selected drive and stores the three 
header words in the FIFO RAM. The first word, WD1, includes the cylinder address, the head se- 
lected, and the sector address. The second word, WD2, is all zeros. The third word, WD3, has the head- 
er CRC information. These words can be read from the FIFO RAM buffer by consecutive read MPR 
instructions. Three read MPR instructions are needed to read three FIFO words. Reading the first 
header word provides enough head positioning information to permit software computation of the cylin- 
der difference for another Seek command to a new track address. 

5.6 WRITE DATA (5) 

Prerequisite: The head must be loaded at the correct track, by issuing a Seek command if necessary. 
The 2's complement of the words to be written (word count) must be loaded into the MPR. 

The Write Data command enables the controller DMA circuitry. The RLV12 becomes LSI-1 1 bus 
master, and data words are loaded into the FIFO buffer. When the drive is ready, header information is 
read from the disk and compared with the first sector address stored in the DAR. Once a header match 
is found, the FIFO data is written on the disk in sequential sectors until the word count is complete. The 
BAR and word count are incremented for each word transferred. If only part of a sector is filled by the 
new data, the rest of the sector area is filled with 0s. At the end of the sector, the sector part of the 
DAR is incremented. At the end of a transfer, CRDY is set and an interrupt is made if IE is set. 

5.7 READ DATA (6) 

Prerequisite: The head must be loaded at the correct track, by issuing a Seek command if necessary. 
The 2's complement of the words to be read (word count) must be loaded into the MPR. 

The Read Data command causes headers to be read from the disk and compared to the sector address 
stored in the DAR. When a header match is found, disk data words are transferred into the FIFO mem- 
ory. Both the BAR and word count are incremented for each word transferred. After four words are 
read from the disk, the microsequencer starts a DMA transfer on the LSI-1 1 bus. The data transfer 
ends when the word counter overflows. If the word count is not complete, the next sector is read. Other- 
wise, CRDY is set and an interrupt is made if IE is set. 

5.8 READ WITHOUT HEADER CHECK (7) 

Prerequisite: The location of the sector with the bad header must be known. The BAR must be loaded 
with the starting memory location to place the words to be read. The MPR must be loaded with the 
word count in 2's complement form. 
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The Read Without Header Check allows the recovery of data if the headers cannot be read. If header 
not found (HNF) or header CRC (HCRC) errors are found on a sector, then data cannot be recovered 
by the usual Read Data command. 

A Seek command must be issued to position the head on the sector with the bad header. Then the sector 
preceding the bad sector must be found by performing consecutive Read Header commands. Finally a 
Read Without Header Check command must be issued within 300 jus to recover the data in the bad 
sector. The BAR and word count are incremented for each word transferred. Data CRC is checked at 
the end of a sector. If the word count is not complete, the next sector is read. Otherwise, CRDY is set 
and an interrupt is made if IE is set. 

NOTE 

The DAR is automatically incremented after each 
sector is transferred. 

5.9 MAINTENANCE FUNCTION (0) 

Prerequisite: The BAR must be set to the first location of a test data buffer. The word count register 
must be set to transfer 51 1 words (11 7701 g). Too large or too small a WC results in a HNF error. (To 
be compatible with RLV1 1 software, a WC of 510 should not be used.) 

The maintenance function allows the RLV12 to perform a self-test operation. This function is used to 
test the controller and may be executed with or without a disk drive attached. The maintenance func- 
tion performs six internal tests as follows. The DAR is incremented after completion of each test. 



Test Function 

1 and 2 Check internal logic 

3 Checks DMA transfers 

4 Checks the CRC of (DAR + 3) 

5 Checks the CRC of (DAR + 4) 

6 Checks the CRC of (CRC of DAR + 4) 



CAUTION 

Memory locations are modified by this function. 

Under DMA control, 256 words are transferred from memory, beginning at the starting address in the 
BAR through BAR + 776s, to the FIFO RAM. Then all but the last word is transferred back into the 
next 255 memory locations, starting at BAR + 1000s through BAR + 1774g. 

Next, the contents of the DAR are used to test the serial read/write data paths. The data uses an inter- 
nal loop and is not transmitted to the disk drive. The CRC of the DAR + 3 and the CRC of the (CRC 
of DAR + 4) are stored in the FIFO RAM and can be read by reading the MPR. The DAR's low byte 
(bits 0-7) holds its original contents + 6. 

The DAR's high byte (bits 8-1 5) is not incremented even when an overflow occurs out of the low byte. 
5.10 EXAMPLES OF USING COMMANDS 

Paragraphs 5.10.1 and 5.10.2 provide examples of the use of RLV12 commands in software programs. 
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5.10.1 Seek Operation 

The following example illustrates the sequence of events for programming a seek operation. 

1. Issue a Read Header command to the desired disk drive and wait for an interrupt request or 
wait for CRDY. 

2. Check error flag in the CSR. 

3. Read the header word from the MPR. 

4. Compute the difference address and the direction for the seek. 

5. Write the difference word into the DAR. 

6. Issue the Seek command to the drive and wait for seek to be completed as indicated by 
DRDY. 

7. Check error flag in the CSR. 

Steps 1, 2 and 3 above are not needed for the next Seek commands if the software program keeps the 
current cylinder address and head selected in memory. 

Reading sequential headers gives head position and present direction so the program can optimize the 
shortest distance to the new location. 

5.10.2 Data Transfer Operation 

The following example illustrates the sequence of events for programming a data transfer (read or 
write) operation. 

1. Perform the steps of the seek operation previously described. 

2. Write the bus address in the BAR. 

3. Write the extended bus address in the BAE if using 22-bit addressing. 

4. Write the DAR with the cylinder address, head selected, and sector address of the first disk 
location to be transferred. 

5. Load the MPR with the word count (2's complement of words to be transferred). 

6. Issue a Read Data, Write Data, or Write Check command in the CSR. 

7. Wait for interrupt or test for CRDY. 

8. Check the CSR for an error flag. 

Seek commands or data transfer commands may be given to other drives between issuing a Seek to the 
first drive and issuing a data transfer command. 

As soon as a Seek command is issued to the first drive, it returns an interrupt and sets CRDY. A Seek 
command may be given to another drive while the first drive is seeking. No interrupts occur when all 
the seeks are complete, so as soon as all Seek commands are issued, data transfer commands may be 
issued. Starting with the drive that was given the shortest seek distance makes it possible for the drive 
that completes its seek first to immediately perform its data transfer and interrupts when done. 
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5.11 ERROR RECOVERY 

Errors can be detected and flagged in the RLV12 and RL01/RL02 subsystem. Some of the errors can 
be recovered; that is, if the operation is tried again, the error may not occur again. Some of the errors 
are fatal and could result in loss of the data, or damage to the media or equipment. The errors are listed 
with the recommended action in Table 5-1. The following examples suggest the kinds of questions to 
consider when programming error recovery routines. 

The type of error is a factor in determining how many times to retry the operation. For example, a data 
late (DLT) error could be caused by a hardware system failure, but it could also be the result of bus 
activity by other I/O devices exceeding their throughput capability for a short duration. In the later 
case, the operation could be successful on the first retry. 



The rate of error occurrence is a good indicator of system performance. An error logging routine should 
be used to obtain this information. If the rate of DLT errors increases, it could indicate hardware sys- 
tem failures, or it could indicate that the system is reaching its throughput capacity in its present con- 
figuration. 



Another example of applying practical consideration to an error is with a header not found (HNF) er- 
ror. After a retry, if the error occurs again, then possibly the head is not positioned over the correct 
track. If a read header operation is performed and the address for the media is examined, the current 
cylinder and head can be determined to see if it is a position problem. If it is not, then possibly there is a 
bad spot on the media and another area should be tried. If there is a bad header, that sector address 
should be entered into the Bad Sector File on the disk and the software should not use this bad sector. 



Error log files should be maintained and consulted to help determine error causes. When an error oc- 
curs, the program should log it with facts such as the contents of the registers, the status of the unit, and 
whether or not a retry was successful The more complete the error log, the faster the cause can be 
diagnosed. 
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Table 5-1 Controller Status Errors 



Controller 
Error 


CSR 
Bit(s) 


Recommended Action 


OPI 


10 


Operation incomplete; retry a limited number of times. 


DCRC/HCRC 


1 1 


Data or header CRC error; retry a limited number of times. Record the contents of the 
DAR. 


DLT 


12 


Data late; retry. 


HNF 


10, 12 


Header not found; perform a Read Header command and verify cylinder. 


NXM 


13 


Nonexistent memory; retry once. Record the contents of the BAR. 


Parity Error 
Abort 


10, 13 


The command to the controller is aborted; retry. 


Drive Error 


14 


Perform a Get Status command and check M PR for disk drive status errors; see Table 5-2. 


Table 5-2 Disk Drive Status Errors 


Drive fVf FK Drive 
Error Status Bit 


Recommended Action 


CO 5 




Cover open; close cover. 


DSE 8 




Multiple drive selection is detected. Retry once before telling operator to verify unit select plug. 


WGE 10 




Write gate error; retry. Drive is not ready, drive is write protected, or drive has another error. 


SPE 1 1 




Spin error; retry. 


SKTO 12 




Seek time out; reset drive and wait for 1.5 second before sending another Seek command. 


WL 13 




Write lock; drive is write protected. 


CHE 14 




Current head error. This error is fatal; do not retry. Write current is detected in the heads. 


WDE 15 




Write data error. This error is fatal; do not retry. No transitions are detected. 
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CHAPTER 6 
DISK DRIVE 



6.1 INTRODUCTION 

The RLV12-AK and the RLV22-AK come complete with an RL01 or RL02 disk drive, respectively. 
The following switches and indicators are found on the front of the disk drive (see Figure 6-1). 

Run/Stop switch with LOAD indicator 
Unit Select plug with READY indicator 
FAULT indicator 

WRITE PROTECT switch and indicator 

Power ON/OFF control is a circuit breaker switch on the back of the disk drive. Operation of this 
switch will not damage the drive; however, this switch is usually left ON. 

The user can select the voltage and range for each disk drive on the back of the drive. 




WRITE 
PROT 



Figure 6-1 RL01/RL02 Disk Drive (Front View) 
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6.2 USER SWITCHES AND INDICATORS 

This paragraph provides information on each switch and indicator. 

Run/Stop Switch with LOAD Indicator - The run/stop switch when pressed, energizes the spindle mo- 
tor. When pressed again, the switch turns off the spindle motor as long as the heads and brushes are 
home. If the heads are loaded, pressing the switch causes the heads to unload and then turns off the 
spindle motor. 

The switch has a mechanical memory. If the spindle motor is energized and the main power is lost for a 
short time, the spindle motor energizes again. 

The LOAD indicator is on when the spindle is stopped, head is home, brushes are home, and the spindle 
motor is not energized. A cartridge can be loaded when this indicator is lit. 

Unit Select Plug with READY Indicator - The unit select plug is a cam button that is inserted in a 
switch. The switch contacts are binary encoded for the unit select number (0, 1, 2, or 3) on the cam 
button. The READY indicator lights to indicate a drive ready condition; that is, the heads are loaded 
on a cylinder ready for a read or a write operation. 

FAULT Indicator - The FAULT indicator comes on when an error condition occurs in the drive. 

WRITE PROTECT Switch and Indicator - The WRITE PROTECT switch, when pressed, sets the 
drive in write protect mode. If the drive is in the process of writing at the time that the switch is 
pressed, writing continues until the next sector pulse. The WRITE PROTECT indicator is on when the 
write protect function is enabled. Pressing the WRITE PROTECT switch again turns off the write 
protect mode and indicator. 

6.3 110/220 VOLTAGE AND NORMAL/LOW VOLTAGE RANGE SETTING 

The voltage selection and voltage range are each set by a terminal block cover, shown in Figure 6-2. 
They should be set according to Table 6-1. 

For systems operating with low line voltage, proceed as follows to change the NORMAL/LOW termi- 
nal block cover. 

1. Remove the two screws from the NORMAL/LOW terminal block cover. 

2. Withdraw the cover and reinsert it turned upside down. 

3. After insertion, "LOW' 1 must be showing through the small window in the cover. 

4. Replace the two screws. 

For systems operation at 220 Vac, 50 or 60 Hz, proceed as follows to change the voltage selection. 

1. Remove the two screws from the 1 10/220 terminal block cover. 

2. Withdraw the cover and reinsert it upside down. 

3. After insertion, "220" must be showing through the small window in the cover. 

4. Replace the two screws. 
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NORMAL/LOW 
TERMINAL BLOCK 
COVER 



TERMINATOR 



110/220 
TERMINAL 
BLOCK COVER 



Figure 6-2 RL01/RL02 Disk Drive (Rear View) 



Table 6-1 Voltage and Range Selector Setting 



Line Voltage 



110/220 
Setting 



NORMAL/LOW 
Setting 



90-105 Vac 
100-127 Vac 
180-210 Vac 
200-254 Vac 



110 
110 

220 
220 



LOW 

NORMAL 

LOW 

NORMAL 
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